Foxit PDF SDK
FoxitPDFSDKPython2.SignatureCallback类 参考

继承自 FoxitPDFSDKPython2._object .

Public 成员函数

def CheckCertificateValidity (cert_path, cert_password, client_data)
 用于检查证书有效性的回调函数。 更多...
 
def ContinueCalcDigest (client_data, pause)
 用于继续自定义摘要计算过程的回调函数。 更多...
 
def GetDigest (client_data)
 用于在计算过程完成后获取摘要的回调函数。 更多...
 
def IsNeedPadData ()
 用于检查在调用回调函数FoxitPDFSDKPython2.SignatureCallback.VerifySigState 时 是否返回所有带有填充零的内容的回调函数。 更多...
 
def Release ()
 用于释放当前回调对象自身的回调函数。 更多...
 
def Sign (digest, digest_length, cert_path, cert_password, digest_algorithm, client_data)
 用于执行签名并返回签名数据的回调函数。 更多...
 
def Sign (digest, digest_length, cert_file_stream, cert_password, digest_algorithm, client_data)
 用于执行签名并返回签名数据的回调函数。 更多...
 
def StartCalcDigest (file, byte_range_array, size_of_array, signature, client_data)
 用于启动自定义摘要计算的回调函数,主要用于初始化计算过程。 更多...
 
def VerifySigState (digest, digest_length, signed_data, signed_data_len, client_data)
 用于验证签名完整性并返回验证状态的回调函数。 更多...
 

静态 Public 属性

 e_CertCannotGetPrivateKey = _fsdk.SignatureCallback_e_CertCannotGetPrivateKey
 无法获取证书的私钥。
 
 e_CertDataError = _fsdk.SignatureCallback_e_CertDataError
 证书数据错误。
 
 e_CertExpired = _fsdk.SignatureCallback_e_CertExpired
 证书已过期。
 
 e_CertInvalidPassword = _fsdk.SignatureCallback_e_CertInvalidPassword
 证书密码错误。
 
 e_CertInvalidPath = _fsdk.SignatureCallback_e_CertInvalidPath
 证书路径错误。
 
 e_CertNotSet = _fsdk.SignatureCallback_e_CertNotSet
 证书未设置为签名。
 
 e_CertUnsupportType = _fsdk.SignatureCallback_e_CertUnsupportType
 证书是不支持的类型。
 
 e_CertValid = _fsdk.SignatureCallback_e_CertValid
 证书有效。
 

详细描述

此类表示用于签名或验证签名的回调对象。 此类中的所有纯虚函数都用作回调函数,应由用户实现, 以便以自定义方式签名或验证签名。
用户可以通过函数FoxitPDFSDKPython2.Library.RegisterSignatureCallback 将自定义签名回调对象注册到Foxit PDF SDK,使用过滤器和子过滤器作为回调名称。

参见
FoxitPDFSDKPython2.Library

成员函数说明

◆ CheckCertificateValidity()

def FoxitPDFSDKPython2.SignatureCallback.CheckCertificateValidity (   cert_path,
  cert_password,
  client_data 
)

用于检查证书有效性的回调函数。

当调用函数FoxitPDFSDKPython2.Signature.StartSign 时会触发此回调函数。 如果不需要检查证书,可以直接返回值FoxitPDFSDKPython2.SignatureCallback.e_CertValid

参数
[in]cert_path将用于签名的证书文件的完整路径(包括文件名和扩展名)。 这是用户从函数FoxitPDFSDKPython2.Signature.StartSign 传递的。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。这是用户从函数FoxitPDFSDKPython2.Signature.StartSign 传递的。
[in]client_data用户定义的对象,由用户从函数FoxitPDFSDKPython2.Signature.StartSign 传递。
返回
证书有效性。请参考从FoxitPDFSDKPython2.SignatureCallback.e_CertValid 开始的值, 应为这些值中的一个。

◆ ContinueCalcDigest()

def FoxitPDFSDKPython2.SignatureCallback.ContinueCalcDigest (   client_data,
  pause 
)

用于继续自定义摘要计算过程的回调函数。

参数
[in]pause决定计算过程是否需要暂停的暂停对象。 如果为null,表示在计算过程中不暂停。 如果不为null,请检查此输入参数的 函数NeedToPauseNow()的返回值,并决定何时暂停计算过程。
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
FoxitPDFSDKPython2.Progressive.e_Finished 表示计算过程已成功完成。
FoxitPDFSDKPython2.Progressive.e_ToBeContinued 表示计算过程尚未完成, 将再次触发回调函数 FoxitPDFSDKPython2.SignatureCallback.ContinueCalcDigest 以继续该过程。
FoxitPDFSDKPython2.Progressive.e_Error 表示发生任何错误。

◆ GetDigest()

def FoxitPDFSDKPython2.SignatureCallback.GetDigest (   client_data)

用于在计算过程完成后获取摘要的回调函数。

当计算过程成功完成时,将触发此回调函数。

参数
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
摘要字符串。 如果出现任何错误,请返回空字符串。

◆ IsNeedPadData()

def FoxitPDFSDKPython2.SignatureCallback.IsNeedPadData ( )

用于检查在调用回调函数FoxitPDFSDKPython2.SignatureCallback.VerifySigState 时 是否返回所有带有填充零的内容的回调函数。

返回
true表示返回内容流中的所有数据(包括填充零), false表示返回流末尾不带填充零的内容数据。

◆ Release()

def FoxitPDFSDKPython2.SignatureCallback.Release ( )

用于释放当前回调对象自身的回调函数。

返回
None.

◆ Sign() [1/2]

def FoxitPDFSDKPython2.SignatureCallback.Sign (   digest,
  digest_length,
  cert_path,
  cert_password,
  digest_algorithm,
  client_data 
)

用于执行签名并返回签名数据的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名过程中被触发。

参数
[in]digest要签名的源文件缓冲区的摘要数据缓冲区。
[in]digest_length摘要数据缓冲区的大小。
[in]cert_path将用于签名的证书文件路径。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。
[in]digest_algorithm签名数据的消息摘要算法。请参考从FoxitPDFSDKPython2.Signature.e_DigestSHA1 开始的值, 这将是这些值中的一个。
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
签名数据。如果出现任何错误,请返回空字符串。
返回的签名数据长度应在默认签名内容长度范围内, 默认长度为7942,或在签名未签名的签名之前通过函数FoxitPDFSDKPython2.Signature.SetDefaultContentsLength 指定的长度。

◆ Sign() [2/2]

def FoxitPDFSDKPython2.SignatureCallback.Sign (   digest,
  digest_length,
  cert_file_stream,
  cert_password,
  digest_algorithm,
  client_data 
)

用于执行签名并返回签名数据的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名过程中被触发。

参数
[in]digest要签名的源文件缓冲区的摘要数据缓冲区。
[in]digest_length摘要数据缓冲区的大小。
[in]cert_file_stream用户实现的FoxitPDFSDKPython2.StreamCallback 对象, 用于访问将用于签名的证书文件内容。
[in]cert_password用于打开证书文件的密码字符串。如果这是空字符串, 表示不需要密码。
[in]digest_algorithm签名数据的消息摘要算法。请参考从FoxitPDFSDKPython2.Signature.e_DigestSHA1 开始的值, 这将是这些值中的一个。
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
签名数据。如果出现任何错误,请返回空字符串。
返回的签名数据长度应在默认签名内容长度范围内, 默认长度为7942,或在签名未签名的签名之前通过函数FoxitPDFSDKPython2.Signature.SetDefaultContentsLength 指定的长度。

◆ StartCalcDigest()

def FoxitPDFSDKPython2.SignatureCallback.StartCalcDigest (   file,
  byte_range_array,
  size_of_array,
  signature,
  client_data 
)

用于启动自定义摘要计算的回调函数,主要用于初始化计算过程。

参数
[in]file签名时,这表示要签名的源文件对象。
验证签名字段时,这表示要验证的源文件对象。
[in]byte_range_array已签名文档(非源文档)的字节范围数组。
此数组中的元素总是成对的偏移-大小值,顺序为: offset,size,offset,size...
[in]size_of_array字节范围数组byte_range_array中的元素数量。
[in]signature签名对象。
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
true表示成功启动计算过程,然后将触发 FoxitPDFSDKPython2.SignatureCallback.ContinueCalcDigest 以继续计算过程。 false表示启动计算过程失败。

◆ VerifySigState()

def FoxitPDFSDKPython2.SignatureCallback.VerifySigState (   digest,
  digest_length,
  signed_data,
  signed_data_len,
  client_data 
)

用于验证签名完整性并返回验证状态的回调函数。

宿主应用程序为自定义签名机制提供此回调函数。 此回调函数将在签名验证过程中被触发。
从7.0版本开始,此回调函数仅用于验证签名的完整性。 有关更多详细信息,请查看有关返回值的注释。

参数
[in]digest要验证的源文件缓冲区的摘要数据缓冲区。
[in]digest_length摘要数据缓冲区的大小。
[in]signed_data签名数据缓冲区。
[in]signed_data_len签名数据缓冲区的大小。
[in]client_data用户定义的对象,由用户从函数 FoxitPDFSDKPython2.Signature.StartSign FoxitPDFSDKPython2.Signature.StartVerify 传递。
返回
验证状态: